//给你两棵二叉树： root1 和 root2 。
//
// 想象一下，当你将其中一棵覆盖到另一棵之上时，两棵树上的一些节点将会重叠（而另一些不会）。你需要将这两棵树合并成一棵新二叉树。合并的规则是：如果两个节点重叠
//，那么将这两个节点的值相加作为合并后节点的新值；否则，不为 null 的节点将直接作为新二叉树的节点。
//
// 返回合并后的二叉树。
//
// 注意: 合并过程必须从两个树的根节点开始。
//
//
//
// 示例 1：
//
//
//输入：root1 = [1,3,2,5], root2 = [2,1,3,null,4,null,7]
//输出：[3,4,5,5,4,null,7]
//
//
// 示例 2：
//
//
//输入：root1 = [1], root2 = [1,2]
//输出：[2,2]
//
//
//
//
// 提示：
//
//
// 两棵树中的节点数目在范围 [0, 2000] 内
// -10⁴ <= Node.val <= 10⁴
//
// Related Topics 树 深度优先搜索 广度优先搜索 二叉树 👍 880 👎 0

package leetcode.editor.cn;

import leetcode.editor.cn.tree.TreeNode;

@SuppressWarnings("all")
//Java：合并二叉树
public class 合并二叉树 {
    public static void main(String[] args) {
        Solution solution = new 合并二叉树().new Solution();
        // TO TEST

        final TreeNode root1 = new TreeNode(1, new TreeNode(3, new TreeNode(5), null), new TreeNode(2));
        final TreeNode root2 = new TreeNode(2, new TreeNode(1, null, new TreeNode(4)), new TreeNode(3, null, new TreeNode(7)));

        solution.mergeTrees(root1, root2);
    }
//leetcode submit region begin(Prohibit modification and deletion)

    /**
     * Definition for a binary tree node.
     * public class TreeNode {
     * int val;
     * TreeNode left;
     * TreeNode right;
     * TreeNode() {}
     * TreeNode(int val) { this.val = val; }
     * TreeNode(int val, TreeNode left, TreeNode right) {
     * this.val = val;
     * this.left = left;
     * this.right = right;
     * }
     * }
     */
    class Solution {
        public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {
            if (root1 == null)
                return root2;
            if (root2 == null)
                return root1;

            merge(root1, root2);
            dfs(root1, root2);

            return root1;
        }

        private void dfs(TreeNode root1, TreeNode root2) {
            if (root1.left != null && root2.left != null) {
                merge(root1.left, root2.left);
                dfs(root1.left, root2.left);
            } else {
                if (root1.left == null)
                    root1.left = root2.left;
                if (root2.left == null)
                    root2.left = root1.left;
            }

            if (root1.right != null && root2.right != null) {
                merge(root1.right, root2.right);
                dfs(root1.right, root2.right);
            } else {
                if (root1.right == null)
                    root1.right = root2.right;
                if (root2.right == null)
                    root2.right = root1.right;
            }


        }

        private void merge(TreeNode root1, TreeNode root2) {
            root1.val = root1.val + root2.val;
            root2.val = root1.val;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)


}
